/**
 * @author: 最帅的的乐乐
 * @date: 2024-05-01 21:37 星期三
 * @motto the harder, the luckier。
 * 给定一个罗马数字，将其转换成整数。
 */

public class _13_RomanToInt {

    public int romanToInt(String s) {
        int sum = 0;
        int preNum = getValue(s.charAt(0));
        for(int i = 1;i < s.length(); i ++) {
            int num = getValue(s.charAt(i));
            if(preNum < num) {
                sum -= preNum;
            } else {
                sum += preNum;
            }
            preNum = num;
        }
        sum += preNum;
        return sum;
    }

    private int getValue(char ch) {
        switch(ch) {
            case 'I': return 1;
            case 'V': return 5;
            case 'X': return 10;
            case 'L': return 50;
            case 'C': return 100;
            case 'D': return 500;
            case 'M': return 1000;
            default: return 0;
        }
    }

    public static void main(String[] args) {
        _13_RomanToInt romanToInt = new _13_RomanToInt();
        System.out.println(romanToInt.romanToInt("MCMXCIV"));
    }
}
